[cosetta].vue 1.3 KB

1234567891011121314151617181920212223242526272829303132333435
  1. <script setup>
  2. const route = useRoute()
  3. const { cosetta, comments } = await $fetch(`/api/cosetta/${route.params.cosetta}`)
  4. const comment = { cosetta_uuid: route.params.cosetta, message: '' }
  5. const addComment = () => $fetch(`/api/comment`, { method: 'POST', body: { ...comment } })
  6. </script>
  7. <template>
  8. <section class="bg-white py-8">
  9. <div class="container mx-auto pt-4 pb-12">
  10. <img v-if='cosetta.images' :src="`/src/public/${cosetta.images[0]}`"/>
  11. <h3 class='uppercase mt-4 font-bold text-xl'>{{cosetta.name}}</h3><br/>
  12. <p class='pt-1 text-gray-700 text-xl'>{{cosetta.description}}</p>
  13. <span class="badge mr-1" v-for='(tag, idx) in cosetta.tags' :key='idx' v-text='tag'></span>
  14. </div>
  15. <div class="container mx-auto">
  16. <p class="font-bold text-xl uppercase">chiacchiere</p>
  17. <div class='form-control'>
  18. <div class='input-group'>
  19. <input v-model='comment.message' class="input input-bordered w-full text-sm" @keypress:enter="addComment"/>
  20. <button class="btn btn-success" @click='addComment'>Invia</button>
  21. </div>
  22. <div class='mt-2' v-for='comment in comments' :key='comment.uuid'>
  23. <span class="label-text-alt" v-text='comment.updatedAt'/>
  24. <div class="alert" v-text='comment.message'/>
  25. </div>
  26. </div>
  27. </div>
  28. </section>
  29. </template>